package edu.upn.evolucion.proventas.datos;

import edu.upn.evolucion.proventas.entidades.Venta;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;

public class VentasPorDiaDAO {
    private static VentasPorDiaDAO instancia;

    private VentasPorDiaDAO() {
    }
    
    public static VentasPorDiaDAO obtenerInstancia() {
        if (instancia == null) {
            instancia = new VentasPorDiaDAO();
        }
        return instancia;
    }
    public ArrayList<Venta> buscar() {
        Connection con = ConnectionManager.getConnection();
        try {
            
            //2. Crear Statement JDBC
            Statement stmt = con.createStatement();
            //3. Crear Sentencias SQL
            //Un objeto ResultSet, almacena los datos de resultados de una consulta
            ResultSet tabla = stmt.executeQuery("SELECT v.fecha,SUM(v.montoTotal) "
                                            + "FROM Venta v "
                                            + "GROUP BY v.fecha "
                                            + "ORDER BY v.fecha");
            
            //System.out.println("Codigo\tNombre");
            ArrayList<Venta> coleccion = new ArrayList<Venta>();
            while(tabla.next()){
                Venta obj = new Venta();
                obj.setNumero(tabla.getString(1));
                obj.setMontoTotal(tabla.getBigDecimal(2));
                coleccion.add(obj);
                //System.out.println(tabla.getInt(1)+"\t"+tabla.getString(2));
            }
            //4. ResultSet
            //5. Cerrar conexion
            stmt.close();
            return coleccion;
        } catch (Exception e) {
            e.printStackTrace(); 
            ArrayList<Venta> c = new ArrayList<Venta>();
            return c;
        } finally {
            try {
                con.close();
            } catch (Exception e) {
            }
        }
    }
}